# -*- coding: utf-8 -*-
"""
 * TencentBlueKing is pleased to support the open source community by making 蓝鲸智云-蓝鲸 PaaS 平台(BlueKing-PaaS) available.
 * Copyright (C) 2017-2021 THL A29 Limited, a Tencent company. All rights reserved.
 * Licensed under the MIT License (the "License"); you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at http://opensource.org/licenses/MIT
 * Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on
 * an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the
 * specific language governing permissions and limitations under the License.
"""
import logging

from django.contrib.auth.signals import user_logged_in

from .client import oauth_client

LOG = logging.getLogger('component')


def update_user_access_token(sender, request, user, *args, **kwargs):
    """自动刷新access_token
    """
    try:
        access_token = oauth_client.get_access_token(request)
        LOG.info('user logged in get access_token success: %s' % access_token)
    except Exception as error:
        LOG.exception('user logged in get access_token failed: %s' % error)


user_logged_in.connect(update_user_access_token)
